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• URL  Related  mistakes  - “No  Route  to....” 
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Routing  Error 


no  route  found  to  match  "/zork"  with  { smethod=>: get) 


The  first  parameter  after  the  :3000/  is  the  name  of  the 
controller.  In  this  case  I mistakenly  used  “zork”  - the 

application  name. 

“No  route  found”  is  saying  - “Looking  at  this  URL,  I see  no 
controller  named  zork  - so  I have  no  clue  where  to  go”. 
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Find  me  in  app/vicws/one/indcx.rhtml 
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The  fix  is  to  use  the  name  of  your  controller  as  the  first  thing 

after  the  host  and  port. 
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http: //local host: 3000/one /index. rhtml 
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Routing  Error 


no  route  found  to  match  " /one/ index . rhtml " with  { ; method->lfc^ t > 


After  the  controller  (one)  the  next  parameter  is  an  action, 
index.rhtml  is  the  view  associated  with  the  “index”  action. 

The  rails  system  takes  URLs  and  hands  them  to  actions  - it  is 
not  serving  files.  Files  in  Rails  applications  come  from  the 
public  folder  and  have  a different  path. 
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M http://localhost:3000/one/index 
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One#index 

Find  me  in  app/vicws/one/indcx.rhtml 


• Q.»  Google 
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Now  you  are  sending  the  request  to  the  action  named 
“index”  in  the  controller  named  “one”. 

The  text  is  coming  from  the  file  “index.rhtml”  but  that  is 
happening  after  the  controller  processes  the  action  and  then 

triggers  the  view. 
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Action  Controller:  Exception  caught 
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NoMethodError  in  One#index 

Showing  app/views/one/index. rhtml  where  line  #3  raised: 


undefined  method  'then'  for  TimesClass 


Extracted  source  (around  line  #3): 


1:  <hl>One#index</hl> 

2:  <p>Pind  me  in  app/views/one/index. rhtml</p> 
3:  <p>Time  <%=  Time. then  %></p> 


This  is  telling  you  that  you  have  an  error  in  a file  (I) 
index.rhtml  - it  even  tells  you  the  path  of  the  file  within  the 
application.  It  tells  you  what  is  wrong  (as  it  imagines  it)  and 
what  line  it  detected  the  error.  This  one  is  easy.  It  should  be 

Time. now  instead  ofTime.then. 
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NoMethodError  in  OneController#thanks 

undefined  method  'info'  for  Logger :Class 

RAILS_ROOT:  . /script /.. /config/ . . 

Application  Trace  | Framework  Trace  | Full  Trace 

/UserB/csev/dev/railB_apps/appO/app/controllerB/one_controller . rb: 14 : in  ' thanks  1 
/Library /Ruby /Gems/1 1 . 8 /gems /rails- 1 .2.6 / lib /commands/ servers /mongrel . rb : 60 
/Library /Ruby /Gems /I . 8 /gems /rails- 1 . 2 . 6 /lib/commands /server . rb : 39 


A 


This  is  an  error  in  the  controller  - it  tells  you  the  file  name 
(underlined)  and  the  line  number  in  the  file.  It  also  tells  you 
(undefined  method)  what  it  thinks  is  wrong. 


Action  Controller:  Exception  caught 


◄ | ► <5  R-*  + ' * http://localhost:3000/one/thanks/  ■ Q- Google 

CD  H CT  Tw  Tz  U-Mt  Ant  18k  13k  dr  Gm  Gc  src  Jira  Try  Python  182  » 

NoMethodError  in  OneController#thanks 


undefined  method  'info'  for  Logger :Class 

RAILS_ROOT:  . /script/ .. /config/ . . 
Application  Trace  | Framework  Trace  | Full  Trace 


/\ 


/Users/csev/dev/rails  apps/ appO /app/controllers /one  controller . rb: 14 : in  * thanks ' 
/Library /Ruby /Gems/ 1 . 8 /gems /rails- 1 . 2 . 6 /lib/ commands/ servers /mongrel . rb : 60 
/Library /Ruby /Gems/1 . 8 /gems /rails- 1 . 2 . 6 /lib/commands /server . rb ; 39 


Capitalized  by 
mistake  on  line  14. 


def  thanks 

logger.info  "Welcome  to  the  thanks  action  in  the  controller" 
Logger.info  params[:yourname] 
if  params[:yourname]  &&  params[:yourname]  ==  "Chuck" 
@barcelona  = "Membership  approved." 
else 

@barcelona  = "Membership  pending" 
end 
end 


Jf 

*<SS  004-0  0 

□ 

▼ 

► < 
a 

■w 

i ► 

B-J  J1_J 

O one_controller.rb  (/Users/csev/dev/rails_apps/appO/app/controllers/) 

t 1 

1 

2 

3 

4 

5 

6 

7 

8 
9 

10 

II 

-- 

13 

14 

15 

16 
1 1 
18 

19 

20 
2. 
22 


class  OneController  < ApplicationController 

def  index 
end 

def  about 
end 

def  contact 
end 

def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller" 
L ogg  e r . inf  o pa  rams [ : your name ] 

if  pa rams [ syourname]  &&  pa rams [ syourname]  ==  "Chuck" 
(Ibarcelona  = "Membership  approved.  " 
else 

@barcelona  = "Membership  pending" 

end 

end 
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File  Edit  Search  Markers  Folding 

* to  n ■ 

▼ Commands  ▼ Plugins  ▼ Favorites  ▼ 
v Path:  /csev/dev/rails_apps/appO  ▼ 

| 0 Filter:  *[*-#]  ▼ 


jEdit  - one_controller.rb 
Utilities  Macros  Plugins 


Help 


csev 
a dev 
^ rails_apps 


Name 
v&app 

vgsr  controllers 

] application.rb 
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New  View 
New  Plain  View 
Close  View 

Go  to  Previous  Buffer  (C+PAGE_UP) 

Go  to  Next  Buffer  (C+PAGE_DOWN) 

Go  to  Recent  Buffer  (C+BACK_QUOTE) 
Show  Buffer  Switcher  (A+BACK_QUOTE) 


* Line  Numbers  (C+e  C+t) 


Type 

Directory 

Directory 

File 


one  controller. rb  File 

helpers  Directory 

models Directory 


Scrolling 

Splitting 

Docking 


end 

end 


@barcelona  = "Membership  pending 


jEdit  Tip:  Show  line  numbers  while  editing. 


View  ->  Line  Numbers 


Action  Controller:  Exception  caught 


◄ | ► <5  R-*  + ' * http://localhost:3000/one/thanks/  ■ Q- Google 
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NoMethodError  in  OneController#thanks 


undefined  method  'info'  for  Logger :Class 

RAILS_ROOT:  . /script/ .. /config/ . . 
Application  Trace  | Framework  Trace  | Full  Trace 


/\ 


/Users/csev/dev/rails  apps/ appO /app/controllers /one  controller . rb: 14 : in  * thanks ' 
/Library /Ruby /Gems/ 1 . 8 /gems /rails- 1 . 2 . 6 /lib/ commands/ servers /mongrel . rb : 60 
/Library /Ruby /Gems/1 . 8 /gems /rails- 1 . 2 . 6 /lib/commands /server . rb ; 39 


Capitalized  by 
mistake  on  line  14. 


def  thanks 

logger.info  "Welcome  to  the  thanks  action  in  the  controller" 
Logger.info  params[:yourname] 
if  params[:yourname]  &&  params[:yourname]  ==  "Chuck" 
@barcelona  = "Membership  approved." 
else 

@barcelona  = "Membership  pending" 
end 
end 


Action  Controller:  Exception  caught 

•<  | ► | | 6 | | | + 0 http://localhost:3000/one/thanks/  * ^Q,-  Coogle 

CO  H CT  Tw  Tz  U-M»  Ant  18k  13k  dr  Cm  Cc  src  Jira  Try  Python  182  601  Fed-G4  Holt  port-py  woa  woa2  woa3 


SyntaxError  in  OneController#thanks 


/l)sers/csev/dev/rails  apps/appO/app/controllers/one  controller . rb: 22 : syntax  error,  unexpected  Send,  expecting  kEND 


RAILS_R00T : . / script/ . . /conf ig/ . . 

Application  Trace  | Framework  Trace  | Full  Trace 

/System/Library/Praraeworks/Ruby . f ramework/Versions/1 . 8/usr/lib/ruby/ gems/1 . 8/gems/activesupport-l . 4 . 4/lib/active  support/dependencie 

/System/Library/Prameworks/Ruby . f ramework/Versions/ 1 . 8/usr/lib/ruby/gems/ 1 . 8/gems/activesupport-l . 4 . 4/lib/active_support/dependencie 

/System/Library/Prameworks/Ruby . f ramework/Versions/ 1 . 8/usr/lib/ruby/gems/ 1 . 8/gems/activesupport-l . 4 . 4/lib/active_support/dependencie 

, / Sx.Sj-em./JJ-b.ra rv/Pra m^w/iTck_9-/_9jihy.._fx.9jn^wo_rl<_/Vfi.risji f> n « / 1 , 8 /nsr /!  j h/ruhv /imro.gAl---8ZaeTn.6Xa.ati-VeB.i.tn.n.or t - 1 .4.4/1  ih/art  ivp  Rnnnnrt  /ripnanHonrip 
r i i » 


This  “expecting  kEND”  error  is  the  single  largest  time  waster 
of  of  students.  Often  it  results  in  hours  of  flailing  around. 
Many  times  the  only  solution  is  to  wait  several  days  until  lab 
at  which  point  the  instructor  solves  it  in  30  seconds. 

This  means  that  you  very  much  appreciate  the  nice  instructor 
- but  you  decide  to  hate  computers  and  decide  that  you  will 
just  hire  programmers  from  this  point  on! 


Action  Controller:  Exception  caught 

•<  | ► | | 6 | | | + * * http://localhost:3000/one/thanks/  * ^Q,-  Coogle 
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SyntaxError  in  OneController#thanks 


/l)sers/csev/dev/rails  apps/appO/app/controllers/one  controller . rb: 22 : syntax  error,  unexpected  Send,  expecting  kEND 


RAILS_R00T:  . /script /.. /config/ . . 

Application  Trace  | Framework  Trace  | Full  Trace 

/System/Library/Praraeworks/Ruby . f ramework/Versions/l . 8/usr/lib/ruby/ geras/1 . 8/geras/activesupport-l . 4 . 4/lib/active  support/dependencie 

/Systera/Library/Frameworks/Ruby . f raraework/Versions/ 1 . 8/usr/lib/ruby/geras/ 1 . 8/geras/activesupport-l . 4 . 4/lib/active_support/dependencie 

/Systera/Library/Praraeworks/Ruby . f raraework/Versions/ 1 . 8/usr/lib/ruby/geras/ 1 . 8/geras/activesupport-l . 4 . 4/lib/active_support/dependencie 
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The  most  important  thing  to  remember  is  that  the  line 
number  in  these  messages  is  when  Rails  detects  the  error.  It 
is  not  necessarily  the  line  on  which  you  *made*  the  error. 
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def  index 


def  about 

end 

def  contact 
end 

def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller" 

1 ogg  e r . inf  o pa  rams [ : y ourname ] 

if  pa rams [: your name]  &&  params[ : your name]  ==  "Chuck" 
dbarcelona  = "Membership  approved." 
else 

@barcelona  = "Membership  pending" 
end 

end 


end 

class  OneController  < ApplicationController 
def  index 


def  about 
end 

def  contact 
end 

def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller" 
1 ogg  e r . inf  o pa  rams [ : y ourname ] 

if  pa rams [: your name]  &&  pa rams [ :y ourname]  ==  "Chuck" 
@barcelona  = "Membership  approved." 
else 

@barcelona  = "Membership  pending" 

end 

end 


end 


Which  would  you  rather  read? 


We  are  not  forced  to  neatly 
indent  our  code  - Ruby  is  pretty 
tolerant  of  whitespace.  But  for  us 
to  read  our  own  code  - indenting 
makes  a lot  of  sense. 

Line  up  the  def  - end  pairs 
Line  up  the  if  - end  pairs 
Indent  the  code  “within”  the  if- 
end  and  def-end  pairs. 


class  OneController  < ApplicationController 
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def  index 


def  about 
end 

def  contact 
end 

def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller" 
1 ogg  e r . info  pa  rams [ : y ourname J 

if  pa rams  I : your name]  &&  pa rams [ :yournamel  ==  "Chuck". 

Obarcelona  = "Membership  approved.", 
else 

@barcelona  = "Membership  pending" 

end 

end 


22 


end 


Lining  things  up  makes  it  easier  to  see  your  mistakes  - if  you  are  stuck  struggling 
with  a“l<END”  error  - don’t  just  try  to  fix  it  by  throwing  in  more  “end” 
statements  - first  neaten  up  a bit.  It  will  take  a minute  or  two  and  you  will  be 
much  happier.  As  you  neaten  up  - you  might  just  come  across  the  error. 


class  OneController  < ApplicationController 
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def  index 


def  about 
end 

def  contact 
end 

def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller" 
logger. info  params[ ryourname] 

if  pa rams  I : your name]  &&  pa rams [ :yournamel  ==  "Chuck" 
Obarcelona  = "Membership  approved.", 
else 

Qbarcelona  = "Membership  pending" 

end 

end 


22 


end 


Stare  at  this  for  a while  and  see  if  you  can  spot  the  error.... 

See  if  you  can  find  the  “missing”  end. 

Count  how  many  if/def/class  lines  there  are  and  count  how 
many  end  lines  there  are.  The  number  should  be  the  same. 


class  OneController  < ApplicationController 
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def  index 


de£  about 
end 

def  contact 
end 


'one  controller . rb : 2 2 : syntax  error,  unexpected 
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def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller 
logger . inf o params [ : yourname ] 

if  params [: yourname]  &&  params] : yourname]  ==  "Chuck" 
@barcelona  = "Membership  approved." 
else 

@barcelona  = "Membership  pending" 

end 


II 


$end , 


expecting  kEND 


This  is  maddening  - the  stupid  thing  is  looking  for  an  end  - and  there  is  already 

an  end  there  - what  more  does  it  want? 

Wrong  approach  - “If  you  want  an  *%$&#!  “end”  I will  give  you  an  end” 
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class  OneController  < ApplicationController 
def  index 


def  about 
end 

def  contact 
end 


We  add  an  “end”  at  the 
end  after  that  last  “end”. 
It  wants  an  “end”  - lets 
give  it  an  “end”. 


def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller 
1 ogg  e r . inf  o pa  rams [ : yourname ] 

if  params[ : yourname 1 &&  pa rams [: yourname]  ==  "Chuck" 
@barcelona  = "Membership  approved. " 
else 

Obarcelona  = "Membership  pending" 

end 


We  hit  refresh  and  the 
error  goes  away. 
Success  ??? 


end 

end  end 


http: //local  host:3000/one/than  ks/ 

◄ | ► <5  R-;  + 0 http://localhost:3000/one/thanks/  * Q- Google 

CP  H CT  Tw  Tz  U-Mv  Ant  18k  13k  dr  Cm  Cc  src  Jira  Try  Python  182  » 


One#thanks 

Find  me  in  app/vicws/onc/thanksjhtml 


class  OneController  < ApplicationController 
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def  index 


def  about 
end 

def  contact 
end 


def  thanks 


logger. info  "Welcome  to  the  thanks  action  in  the  controller 
1 ogg  e r . inf  o pa  rams [ : yourname ] 

if  pa  rams [ : yourname ] &&  pa  rams [ : yourname ] ==  " Chuck " 
@barcelona  = "Membership  approved." 
else 

Obarcelona  = "Membership  pending" 

end 


end 

end  end 


http: //local  host:3000/one/than  ks/ 

◄ | ► <5  R-;  + 0 http://localhost:3000/one/thanks/  * Q-  Coogle 

Q3  H CT  Tw  Tz  U-Mt  Ant  18k  13k  dr  Cm  Cc  src  Jira  Try  Python  182  » 


Not  success  at  all  - we  fixed  a 


One#thanks 


syntax  error  but  ruined  the  logic  of 
our  code.  The  if-end  and  def-end 


Find  me  in  app/vicws/onc/thanksjhtml 


pairs  tell  Ruby/Rails  what  goes 
where  - it  defines  blocks  of  code. 


class  OneController  < ApplicationController 
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def  index  r\  ^ http://localhost:3000/one/thanks/ 

■<  C + I"  1 1 p , 1 1 o c a I h o s t : 3 0 0 0 / o n e / 1 h a n k s * ^Q,-  Google 

def  about  QQ  H CT  Tw  Tz  U-Mt  Am  18k  13k  dr  Cm  Cc  src  Jira  Try  Python  182  » 

end 

One#thanks 

def  contact 
end 

Find  me  in  app/views/onc/thanksjhtml 

def  thanks 

logger. info  "Welcome  to  the  thanks  a 
1 ogg  e r . inf  o pa  rams [ : yourname ] 
if  pa  rams [ : yourname ] &&  pa  rams [ : your 
dbarcelona  = "Membership  approved 
else 

Obarcelona  = "Membership  pending" 

end 

end 

end  end 


If  you  solve  this  syntax  error  by  adding  an  end  at  the  end  - your  syntax  error  will 
go  away-  but  the  program  will  not  function.  Several  hours  later  you  will  figure 
out  that  your  “thanks”  action  is  not  actually  executing  because  your  thanks  action 
is  now  part  of  the  index  action  - because  of  where  you  put  the  end. 
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O one_controller.rb  (/ Users /csev/ dev/ rails_apps/appO/app/ controllers/) 
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class  OneController  < ApplicationController 
flet  indexi 


def  about 

end 

def  contact 
end 


'one  controller . rb : 22 s syntax  error,  unexpected  $end,  expecting  kEND 


def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller" 
logger. info  params[ :yourname] 

if  pa rams [ :yournamej  &&  pa rams [ : your name]  ==  "Chuck" 
@barcelona  = "Membership  approved." 
else 

@barcelona  = "Membership  pending" 

end 

end 


end 


found  end-of-file;  expected  ‘rescue’,  ’ensure’,  ’end’,  ’else’, 


This  is  where  the  RubyPlugin  in  jEdit  earns  every  penny  of  its  free 
price.  Put  your  cursor  on  the  offending  end.  jEdit  will  count  the  if/ 
def/class  and  end  statements  and  show  you  which  statement 

“matches”  the  offending  end. 
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O one_controller.rb  (/ Users /csev/ dev/ rails_apps/appO/app/ controllers/) 


class  OneController  < ApplicationController 
del  indexi 


def  about 

end 

def  contact 
end 


: : 
12 

13 

14 

15 

-t. 

I? 

18 

20 

22 


def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller” 
logger . inf  o params [ : yourname ] 

if  params [: yourname]  &&  params] : yourname]  ==  "Chuck" 
@barcelona  = "Membership  approved." 
else 

@barcelona  = "Membership  pending" 

end 

end 

end 


found  end-of-file;  expected  'rescue',  'ensure',  'end',  'else', 


We  quickly  see  that  the  “end”  on  line  22  matched  with  the  “def  index”  way  back  on  line 
3.  And  then  we  notice  that  there  is  a missing  end  on  line  4 for  the  “def  index”.  The 
error  was  made  on  line  4 and  noticed  on  line  22  because  that  was  when  the  end-of-file 
was  encountered  and  Ruby  realised  it  was  “missing”  an  end. 


O one_controller.rb  (/ Users /csev/ dev/ rails_apps/appO/app/controllers/) 
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fclass  OneControllerl  < ApplicationController 

def  index 
end 

def  about 
end 

def  contact 
end 

def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller" 
logger. info  params[:yourname] 

if  pa rams [: your name]  &&  pa rams [: your name]  ==  "Chuck" 
(jjbarcelona  = "Membership  approved.  " 
else 

@barcelona  = "Membership  pending" 

end 

end 


We  put  the  “end”  on  line  4 in  to  close  the  “def  index”. 

Then  we  click  on  the  “end”  on  line  22  and  see  that  it 
properly  matches  the  “class”  statement  on  line  I. 


O one_controller.rb  (/ Users /csev/dev/rails_apps/appO/app/controllers/) 
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class  OneController  < ApplicationController 

def  index 
end 

def  about 

end 

def  contact 
end 


logger. info  "Welcome  to  the  thanks  action  in  the  controller" 
logger,  info  pa  rams  I : your name ] 

if  pa rams [ :yourname]  &&  params[ :yourname]  ==  "Chuck" 
@barcelona  = Membership  approved. " 
else 

@barcelona  = "Membership  pending" 

end 
efid 

end 


Once  your  program  is  syntax-error  free  - you  can  put  the  cursor 
on  a def  or  class  or  end  line  and  the  Ruby  Plugin  will  bracket  the 
code  between  the  start  and  end.  This  helps  you  keep  track  of 

your  program  logic. 


class  OneController  < ApplicationController 


1 

2 

3 

4 

5 

6 

7 

8 
9 

10 

-- 
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15 

16 
17 
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22 


def  index 


'one  controller . rb : 22 : syntax  error,  unexpected  $end,  expecting  kEND 

def  about 
end 


def  contact 
end 


def  thanks 

logger. info  "Welcome  to  the  thanks  action  in 
1 ogg  e r . inf  o pa  rams [ : yourname ] 
if  params[ : yourname 1 &&  pa rams [: yourname]  == 

@barcelona  = "Membership  approved. " 
else 

Barcelona  = "Membership  pending"  Find  me  in  app/vicws/oncAhanks  rhtml 

end 

end 


http: //local  host:  3000/one/than  ks/ 

■<  | ► | | <5  | | §<:i|  | + 0 http://localhost:3000/one/thanks/  * I'd,*  Coogle 

CQ  H CT  Tw  Tz  U-Mt  Ant  18k  13k  dr  Cm  Cc  sre  Jira  Try  Python  182  » 


One#thanks 


end  end 


If  you  solve  this  syntax  error  by  adding  an  “end”  at  the  end  - your  syntax  error  will 
go  away  - but  the  program  will  not  function.  Several  hours  or  days  later  you  will 
figure  out  that  your  “thanks”  code  has  stopped  executing  because  your  thanks  code 
has  become  part  of  the  index  action  - because  of  where  you  put  the  “end”. 


Action  Controller:  Exception  caught 

< | ► | | C | | §<?|  | + | O http://localhost:3000/one/thanks/  * '0,'-  Google 

CO  H CT  Tw  Tz  U-Mv  Ant  18k  13k  dr  Cm  Cc  src  Jira  Try  Python  182  601  Fed-G4  Holt  port-py  woa  woa2  » 


SyntaxError  in  OneController#thanks 


/Users/csev/dev/rails_apps/appO/app/controllers/one_controller . rb: 22 : syntax  error,  unexpected  kEND,  expecting  Send 


RAILS_R00T:  . /script /.. /config/ . . 
Application  Trace  | Framework  Trace  | Full  Trace 


Text 


/System/Library/Frameworks/Ruby. f ramework/Versions/l . 8/usr/lib/ruby/gems/l . 8/gems/activesupport-l . 4 . 4/lib/active_support/de «_ 
/ Sy s tem/Libr ary /Frameworks /Ruby . f ramework/Versions/l . 8/usr/lib/ruby/gems/l . 8/gems/activesupport-l . 4 . 4 /lib/activesupport/de 


Too  many  end 
statements  gives  the 
same  error  as  too 
few  end  statements. 


If  you  have  too  many  end 
statements  - clicking  on  the 
end  on  line  22  will  not  show  a 
bracket. 


r 


O one_controller.rb  (/ Users /csev/dev/rails_apps/appO/app/controllers/) 


class  OneController  < ApplicationController 

def  index 
end  end 


def  about 
end 

def  contact 
end 

def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller" 
logger. info  params[ :yourname] 

if  pa rams [ :yourname ] Sfi  pa rams [ :yourname]  ==  "Chuck" 
Qbarcelona  = "Membership  approved. " 
else 

@barcelona  = "Membership  pending" 

end 

end 


end 


Action  Controller:  Exception  caught 

◄ | ►J  | C | | §<-': | | + 0 http://localhost:3000/one/thanks/  * '0,'-  Google 

CP  H CT  Tw  Tz  U-Mv  Ant  18k  13k  dr  Cm  Cc  src  Jira  Try  Python  182  601  Fed-G4  Holt  port-py  woa  woa2  » 

SyntaxError  in  OneController#thanks  ] 

/Users/csev/dev/rails_apps/appO/app/controllers/one_controller . rb: 22 : syntax  error,  unexpected  kEND,  expecting  $end 

RAILS_R00T:  . /script /.. /config/ . . 

Application  Trace  | Framework  Trace  | Full  Trace 


/System/Library/Prameworks/Ruby . framework/Versions/1 . 8/usr/lib/ruby/gems/l . 8/gems/activesupport-l . 4 . 4/lib/activesupport/de 
/Systera/Library/Prameworks/Ruby . framework/Versions/1 . 8/usr/lib/ruby/gems/l . 8/gems/activesupport-l . 4 . 4/lib/active  support/de  * 


A 


Traceback 

Information 


The  “trace  back”  information 
is  only  useful  if  it  is  in  your 
code.  All  the  other  stuff  is 
telling  you  about  the  inner 
workings  of  Rails  - not  much 
use  to  you  - ignore  it. 


1 O one_controller.rb  (/Users/csev/dev/rails_apps/appO/app/controllers/) 
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class  OneController  < ApplicationController 


def  about 
end 


def  contact 
end 


def  thanks 

logger. info  "Welcome  to  the  thanks  action  in  the  controller" 
logger. info  params[ :yourname] 

if  pa rams [ :yourname]  s&  pa rams [ :yournamej  ==  “Chuck" 
Qbarcelona  = "Membership  approved.'1, 
else 

@barcelona  = "Membership  pending" 

end 

end 


end 


Dealing  with  kEND  errors 


'one  controller . rb : 22 : syntax  error,  unexpected  $end,  expecting  kEND 


• Do  not  just  start  adding  end  statements  until  the  error  goes  away  - 
your  code  not  have  syntax  errors  - but  it  will  probably  also  not  work 

• There *  *is*  a reason  and  it  is  perfectly  logical  and  with  patience  you 
will  find  it 

• Let  the  RubyPlugin  help  by  showing  you  the  location  of  the  error  (red 
underline)  and  show  you  the  beginning  line  that  corresponds  to  the 
end  line. 


Summary 

• Getting  syntax  errors  can  be  frustrating  for  the  beginning  programmer 

• Keeping  your  code  neat  and  clean  well  indented  helps  avoid  errors  and 
when  you  make  a mistake  - it  is  easier  to  see  the  error. 

• The  error  messages  in  the  browser  and  in  the  logs  can  be  pretty 
verbose.  Ignore  lines  in  trace  backs  that  do  not  refer  to  parts  of  your 
program. 

• In  time  you  will  realize  that  there  are  4-5  typical  typing  mistakes  you 
make  and  quickly  recognize  the  error  messages  when  you  see  them 


